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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3 GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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1 Scope 

The present document contains an electronic copy of the ANSI-C code for the Fixed-point Enhanced aacPlus codec [1]. 

2 References 

The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] 3GPP TS 26.401: "General audio codec audio processing functions; Enhanced aacPlus general 

audio codec; General description". 

[2] 3GPP TS 26.403: "General audio codec audio processing functions; Enhanced aacPlus general 

audio codec; Encoder specification; Advanced Audio Coding (AAC) part". 

[3] 3GPP TS 26.404: "General audio codec audio processing functions; Enhanced aacPlus general 

audio codec; Encoder specification; Spectral Band Replication (SBR) part". 

[4] 3GPP TS 26.405: "General audio codec audio processing functions; Enhanced aacPlus general 

audio codec; Encoder specification; Parametric stereo part". 

[5] ISO/IEC 14496-3 (2001): "Information technology - Coding of audio-visual objects - Part 3: 

Audio". 

[6] ISO/IEC 14496-3:2001/Amd. 1:2003: "Bandwidth Extension". 

[7] ISO/IEC 14496-3:2001/Amd.l:2003/Cor 1:2004. 

[8] ISO/IEC 14496-3:2001/ Amd.2:2004: "Parametric coding for high quality audio". 

[9] 3GPP TS 26.402: "General audio codec audio processing functions; Enhanced aacPlus general 

audio codec; Additional decoder tools". 

[10] 3GPP TS 26.244: "Transparent end-to-end streaming service; 3GPP file format (3GP)". 



3 Definitions and abbreviations 

3.1 Definitions 

For the purposes of the present document, the terms and definitions given in 3GPP TS 26.401 [1], 3GPP TS 26.403 [2], 
3GPP TS 26.404 [3], 3GPP TS 26.405 [4] and 3GPP TS 26.402 [9] apply. 
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3.2 



Abbreviations 



For the purposes of the present document, the following abbreviations apply: 

AAC Advanced Audio Coding 

aacPlus Combination of MPEG-4 AAC and MPEG-4 Bandwidth extension (SBR) 

ANSI American National Standards Institute 

Enhanced aacPlus Combination of MPEG-4 AAC, MPEG-4 Bandwidth extension (SBR) and MPEG-4 

Parametric Stereo 

GSM Global System for Mobile communications 

I/O Input/Output 

MDCT Modified Discrete Cosine Transform 

QMF Quadrature Mirror Filter 

RAM Random Access Memory 

ROM Read Only Memory 

SBR Spectral Band Replication 



4 Fixed point ANSI-C code structure 

This clause gives an overview of the structure of the fixed point ANSI-C code and provides an overview of the contents 
and organization of the C code attached to the present document. 

The C code has been verified on the following systems: 

• IBM PC/AT compatible computers with Windows XP, 2000 and Microsoft Visual C++ v.6.0 compiler. 

• IBM PC/AT compatible computers with Linux OS and GCC v. 3. 3 compiler. 
ANSI-C was selected as the programming language because portability was desirable. 

4.1 Contents of tine fixed point ANSI-C source code 

The C code distribution is organized in two directories for encoder and decoder and further into several subdirectories, 
reflecting the major building blocks of the Enhanced aacPlus codec. The file descriptions on root level as well as the 
directory structure is given as follows. 

Table 1 : Source code directory structure for the encoder (ETSI_aacPlusenc) 



Directory 


Description 


README.txt 


information on how to compile 


Makefile 


UNIX style encoder Makefile 


enhAacPlusenc.dsw 


Win32 MSVC 6.0 encoder workspace 


enhAacPlusenc.dsp 


Win32 MSVC 6.0 encoder makefile 


src/ 


directory for the encoder frontend 


etsiopjastaacenc/ 


AAC encoder library 


etsiop resamplib/ 


resampler library 


etsiop_sbrenclib/ 


SBR encoder library 



Table 2: Source code directory structure for the decoder (ETSI_aacPlusdec) 



Directory 


Description 


README.txt 


information on how to compile 


Makefile 


UNIX style encoder Makefile 


enhAacPlusdec.dsw 


Win32 MSVC 6.0 decoder workspace 


src/ 


directory for the decoder frontend 


etsiop aacdec 


AAC decoder library 


etsiop_sbrdeclib/ 


SBR decoder library 
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Table 3: Source code directory structure common for encoder and decoder 



Directory 


Description 


etsiop bitbuf/ 


bitstream reading/writing library 


etsiop ffrlib/ 


general purpose functionalities 


etsioplib/ 


ETSI operators implementation 


3g lib/ 


precompiled libraries for audio and bitstream file format handling 



The distributed files with suffix "c" contain the source code and the files with suffix "h" are the header files. Within the 
respective libraries, the RAM data is contained in "xxx_ram" files with suffix "c", the ROM data is contained in 
"xxx_rom" files with suffix "c". Makefiles are provided for the platforms in which the C code has been verified (listed 
above). 



A list of source code files is given below: 



Table 4: Encoder source code files 



Directory 


Module 


src/ 


main.c 


mp4file.c 


etsiopjastaacenc/ 


qc main.c 


aacenc.c 


ms stereo. 


spreading. c 


interface.c 


bit cnt.c 


adj thr.c 


quantize. c 


psy configuration.c 


sf estim.c 


tns param.c 


grp data.c 


pre_echo_control.c 


stprepro.c 


tns.c 


dyn bits.c 


psy main.c 


channel_map.c 


block switch. c 


band_nrg.c 


transform. c 


bitenc.c 


line_pe.c 


Stat bits.c 


etsiop_sbrenc/ 


qmf_enc.c 


ton corr.c 


fram gen.c 


env bit.c 


env est.c 


mh det.c 


hybrid. c 


bit sbr.c 


ps_bitenc.c 


sbr main.c 


tran det.c 


sbr misc.c 


code env.c 


nf est.c 


freq sca.c 


invf est.c 


ps enc.c 


etsiop resamplib/ 


downsample FIR.c 
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Table 5: Decoder source code files 



Directory 


Module 


src/ 


main.c 


fileifc.c 


spline resampler.c 


etsiop_aacdec/ 


aacdecoder.c 


streaminfo.c 


channelinfo.c 


stereo. c 


longblock.c 


shortblock.c 


pulsedata.c 


block.c 


pns.c 


imdct.c 


tns.c 


bitstream.c 


channel.c 


conceal. c 


datastream.c 


etsiop_sbrdeclib/ 


env dec.c 


aacpluscheck.c 


env calc.c 


lpp_tran.c 


sbrdecoder.c 


sbr dec.c 


sbr crc.c 


hybrid. c 


ps_bitdec.c 


env extr.c 


freq sca.c 


ps_dec.c 


qmf dec.c 



Table 6: Common source code files 



Directory 


Module 


etsiop bitbuf/ 


bitbuffer.c 


etsiopjfrlib/ 


fft 32x32.0 


transcendent.c 


transcendent enc.c 


intrinsics.c 


vector.c 



4.2 Program execution 



The Enhanced aacPlus codec is implemented in two programs: 

• enhAacPlusEnc.exe. 

• enhAacPlusDec.exe. 

The programs should be called like: 

• enhAacPlusEnc.exe <wav_file> <bitstream_file> <bitrate> <(m)ono/(s)tereo>. 

• enhAacPlusDec.exe <bitstream_file> <wav_file> <mode> [error_pattern_file]. 

The audio files contain 16-bit linear encoded PCM samples with wav header, the bitstream files are of 3 GPP type an the 
error pattern file is a ASCII file, see clause 5. 
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The encoder and decoder command line handling is also explained by running the applications without input arguments. 



4.3 Memory requirements 



The data types of variables and tables used in the fixed-point implementation are defined by the ETSI operator data 
types, the following types are used: 

• Words. 

• Wordl6. 

• Word32. 

• Flag. 

4.3.1 Constants and tables 

This clause contains a listing of all constants and tables contributing to the ROM requirements of the encoder and 
decoder. 

Table 7: Encoder constants and tables 



Name 


Data type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 


LongWindowSine 


Word 16 


1 024 


aac rom.c 


Window coefficients 


ShortWindowSine 


Word 16 


128 


aac rom.c 


Window coefficients 


LongWindowKBD 


Word 16 


1 024 


aac rom.c 


Window coefficients 


fftlwiddlelable 


Word 16 


513 


aac rom.c 


FFT twiddle coefficients 


formfac sqrttable 


Word32 


192 


aac rom.c 


Lookup table for efficient sqrt implementation 


mTab_3_4 


Word32 


1 024 


aac_rom.c 


Quantizer table, used for efficient pow () 
implementation 


mTab_4_3 


Word32 


1 024 


aac_rom.c 


Inverse quantizer table, used for efficient pow () 
implementation 


pow2tominusNover1 6 


Word 16 


17 


aac rom.c 


Lookup table for efficient pow() implementation 


specExpMantTableComb_e 
nc 


Word32 


128 


aac_rom.c 


Lookup table for efficient inverse quantizer 
implementation 


specExpTableComb_enc 


Word8 


32 


aac_rom.c 


Lookup table for efficient inverse quantizer 
implementation 


quantBorders 


Word 16 


16 


aac_rom.c 


Lookup table for efficient distortion calculation 
implementation 


quantBorders 


Word 16 


12 


aac_rom.c 


Lookup table for efficient distortion calculation 
implementation 


p_8000_mono_long 


INS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_8000_stereo_long 


INS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_8000_mono_short 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_8000_stereo_short 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_1 6000_mono_long 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_1 6000_stereo_long 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_1 6000_mono_short 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_1 6000_stereo_short 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_24000_mono_long 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_24000_stereo_long 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p 24000 mono short 


TNS CONFIG T 


5 


aac rom.c 


TNS tuning parameters 
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Name 


Data type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 




ABULATED 








p_24000_stereo_short 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_32000_mono_long 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_32000_stereo_long 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_32000_mono_short 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


p_32000_stereo_short 


TNS CONFIG T 
ABULATED 


5 


aac_rom.c 


TNS tuning parameters 


m log2 table 


Word32 


64 


aac rom.c 


Lookup table for efficient ld() implementation 


tnsCoeff3 


Word32 


16 


aac rom.c 


TNS filter coefficients 


tnsCoeff3Borders 


Word32 


16 


aac rom.c 


TNS filter borders 


tnsCoeff4 


Word32 


32 


aac rom.c 


TNS filter coefficients 


tnsCoeff4Borders 


Word32 


32 


aac rom.c 


TNS filter borders 


tnslnfoTab 


TNS INFO TAB 


20 


aac rom.c 


TNS bitrate to tuning mapping table 


tnsMaxBandsTab 


TNS MAX TAB 
ENTRY 


12 


aac_rom.c 


max. TNS bands per sampling rate table 


huff Itab1 2 


Word 16 


81 


aac rom.c 


Huffman codeword table AAC 


huff Itab3 4 


Word 16 


81 


aac rom.c 


Huffman codeword table AAC 


huff Itab5 6 


Word 16 


81 


aac rom.c 


Huffman codeword table AAC 


huff Itab7 8 


Word 16 


64 


aac rom.c 


Huffman codeword table AAC 


huff Itab9 10 


Word 16 


169 


aac rom.c 


Huffman codeword table AAC 


huff Itab11 


Word 16 


289 


aac rom.c 


Huffman codeword table AAC 


huff Itabscf 


Word 16 


121 


aac rom.c 


Huffman codeword table AAC 


huff ctab1 


Word 16 


81 


aac rom.c 


Huffman codeword table AAC 


huff ctab2 


Word 16 


81 


aac rom.c 


Huffman codeword table AAC 


huff ctab3 


Word 16 


81 


aac rom.c 


Huffman codeword table AAC 


huff ctab4 


Word 16 


81 


aac rom.c 


Huffman codeword table AAC 


huff ctab5 


Word 16 


81 


aac rom.c 


Huffman codeword table AAC 


huff ctab6 


Word 16 


81 


aac rom.c 


Huffman codeword table AAC 


huff ctab7 


Word 16 


64 


aac rom.c 


Huffman codeword table AAC 


huff ctabS 


Word 16 


64 


aac rom.c 


Huffman codeword table AAC 


huff ctab9 


Word 16 


169 


aac rom.c 


Huffman codeword table AAC 


huff ctablO 


Word 16 


169 


aac rom.c 


Huffman codeword table AAC 


huff ctab11 


Word 16 


289 


aac rom.c 


Huffman codeword table AAC 


huff ctabscf 


Word32 


242 


aac rom.c 


Huffman codeword table AAC 


sfb 16000 long 1024 


Word8 


22 


aac rom.c 


Scalefactor band table 


sfb 16000 short 128 


Word8 


8 


aac rom.c 


Scalefactor band table 


sfb 22050 long 1024 


Word8 


24 


aac rom.c 


Scalefactor band table 


sfb 22050 short 128 


Word8 


8 


aac rom.c 


Scalefactor band table 


sfb 24000 long 1024 


Word8 


24 


aac rom.c 


Scalefactor band table 


sfb 24000 short 128 


Word8 


8 


aac rom.c 


Scalefactor band table 


p4 13 


Word32 


26 


sbr rom.c 


Hybrid filterbank coefficients 


p8 13 


Word32 


26 


sbr rom.c 


Hybrid filterbank coefficients 


sbr cos twiddle L32 enc 


Word 16 


16 


sbr rom.c 


QMF filterbank twiddle table 


sbr cos twiddle L64 enc 


Word 16 


32 


sbr rom.c 


QMF filterbank twiddle table 


sbr sin twiddle L32 enc 


Word 16 


16 


sbr rom.c 


QMF filterbank twiddle table 


sbr sin twiddle L64 enc 


Word 16 


32 


sbr rom.c 


QMF filterbank twiddle table 


sbr_alt_sin_twiddle_L32_e 
nc 


Word 16 


17 


sbr_rom.c 


QMF filterbank twiddle table 


sbr_alt_sin_twiddle_L64_e 
nc 


Word 16 


33 


sbr_rom.c 


QMF filterbank twiddle table 


sbr_qmf_64_640_enc 


Word 16 


330 


sbr rom.c 


QMF window coefficients 


aBookPslidTimeCode 


Word32 


58 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslidFreqCode 


Word32 


58 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aHybridResolution 


Word 16 


3 


sbr rom.c 


Number of hybrid bands in each QMF band 


hiResBandBorders 


Word8 


11 


sbr rom.c 


Borders of Parametric Stereo bins 


groupBordersMix 


Word8 


15 


sbr rom.c 


Borders of Parametric Stereo groups 


bins2groupMap 


Word32 


58 


sbr_rom.c 


Mapping of Parametric Stereo bins to Parametric 
Stereo groups 


iidQuantLeft 


Word32 


14 


sbr rom.c 


IID quant values for Parametric Stereo 
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Name 


Data type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 


iidQuantRight 


Word32 


14 


sbr rom.c 


IID quant values for Parametric Stereo 


iccQuant 


Word32 


16 


sbr rom.c 


ICC quant values for Parametric Stereo 












V Huff envelopeLevelCIOT 


Word32 


242 


sbr rom.c 


Huffman codeword table SBR 


V Huff envelopeLevelCIOF 


Word32 


242 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceCI OF 


Word32 


9S 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceCI OT 


Word32 


9S 


sbr rom.c 


Huffman codeword table SBR 


V Huff envelopeLevelCHT 


Word32 


126 


sbr rom.c 


Huffman codeword table SBR 


V Huff NoiseLevelC11T 


Word32 


126 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceCn T 


Word32 


50 


sbr rom.c 


Huffman codeword table SBR 


bookSbrNoiseBalanceCH T 


Word32 


50 


sbr rom.c 


Huffman codeword table SBR 


V Huff envelopeLevelCH F 


Word32 


126 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceC1 1 F 


Word32 


50 


sbr rom.c 


Huffman codeword table SBR 


aBookPslidTimeLength 


Words 


15 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslidFreqLength 


Words 


15 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslccFreqLength 


Words 


S 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslccTimeLength 


Words 


S 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslccFreqCode 


Word 16 


15 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslccTimeCode; 


Word 16 


15 


sbr rom.c 


Huffman codeword table Parametric Stereo 


V Huff envelopeLevelLIOT 


Words 


61 


sbr rom.c 


Huffman codeword table SBR 


v_Huff_envelopeLevelL1 OF 


Words 


61 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceH OF 


Words 


25 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceH OT 


Words 


25 


sbr rom.c 


Huffman codeword table SBR 


V Huff envelopeLevelLUT 


Words 


32 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceLH T 


Words 


13 


sbr rom.c 


Huffman codeword table SBR 


V Huff NoiseLevelL11T 


Words 


32 


sbr rom.c 


Huffman codeword table SBR 


bookSbrNoiseBalanceLH T 


Words 


13 


sbr rom.c 


Huffman codeword table SBR 


v_Huff_envelope Level L1 1 F 


Words 


32 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceH 1 F 


Words 


13 


sbr rom.c 


Huffman codeword table SBR 


logDualisTable 


Word 16 


65 


transcenden 
t.c 


Lookup table for efficient logQ implementation 


pow2Table 


Word32 


512 


transcenden 
t enc.c 


Lookup table for efficient powQ implementation 


FIRenc_band24 


Word 16 


49 


downsample 
FIR.c 


FIR filter coefficients for 2:1 resampling 


FIRenc_band63 


Word 16 


127 


downsample 
FIR.c 


FIR filter coefficients for 3:2 resampling 


tuningTable 


tuningTable 


2S0 


sbr main.c 


SBR tuning parameters 


Sum 




11268 







Table 8: Decoder constants and tables 



Name 


Data 
type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 


tnsCoeffS 


Word 16 


S 


aac rom.c 


TNS filter coefficients 


tnsCoeff4 


Word 16 


16 


aac rom.c 


TNS filter coefficients 


trigData 


Word 16 


513 


aac rom.c 


Sine table, used for efficient sin(), cos() 


OnlyLongWindowKBD 


Word 16 


1 024 


aac rom.c 


Window coefficients 


OnlyShortWindowKBD 


Word 16 


12S 


aac rom.c 


Window coefficients 


OnlyLongWindowSine 


Word 16 


1 024 


aac rom.c 


Window coefficients 


OnlyShortWindowSine 


Word 16 


12S 


aac rom.c 


Window coefficients 


sfb 4S 1024 


Word 16 


50 


aac rom.c 


Scalefactor band table 


sfb 4S 12S 


Word 16 


15 


aac rom.c 


Scalefactor band table 


sfb 32 1024 


Word 16 


51 


aac rom.c 


Scalefactor band table 


sfb 24 1024 


Word 16 


49 


aac rom.c 


Scalefactor band table 


sfb 24 12S 


Word 16 


16 


aac rom.c 


Scalefactor band table 


sfb 16 1024 


Word 16 


44 


aac rom.c 


Scalefactor band table 


sfb 16 12S 


Word 16 


16 


aac rom.c 


Scalefactor band table 


sfb S 1024 


Word 16 


41 


aac rom.c 


Scalefactor band table 


sfb S 12S 


Word 16 


16 


aac rom.c 


Scalefactor band table 


HuffmanCodeBook 1 


Word 16 


204 


aac rom.c 


Huffman codeword table AAC 
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Name 


Data 
type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 


HuffmanCodeBook 2 


Word 16 


156 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 3 


Word 16 


156 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 4 


Word 16 


152 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 5 


Word 16 


164 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 6 


Word 16 


160 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 7 


Word 16 


124 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 8 


Word 16 


124 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 9 


Word 16 


336 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 10 


Word 16 


32S 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 11 


Word 16 


544 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook SCL 


Word 16 


260 


aac rom.c 


Huffman codeword table AAC 


SamplingRatelnfoTable 


Word 16 


45 


aac_rom.c 


Sampling rate to scalefactor mapping 
table AAC 


HuffmanCodeBooks 


mixed 


52 


aac rom.c 


Huffman codeword table AAC 


specExpTableComb 


Words 


52 


aac_rom.c 


Lookup table for efficient exponent 
implementation 


specExpTableMant 


Word32 


104 


aac_rom.c 


Lookup table for efficient exponent 
implementation, mantissa 


InverseQuantTable 


Word32 


514 


aac_rom.c 


Lookup table for efficient inverse quantizer 
implementation 


sgn_mask 


Word 16 


3 


aac_rom.c 


Helper vector for efficient bit-wise 
operations in the TNS module 


neg_mask 


Word 16 


3 


aac_rom.c 


Helper vector for efficient bit-wise 
operations in the TNS module 


tns max bands tbi 


Words 


IS 


aac rom.c 


max. TNS bands per sampling rate table 


sbr limGains m 


Word 16 


4 


sbr rom.c 


SBR limiter gain values, mantissa 


sbr limGains e 


Word 16 


4 


sbr rom.c 


SBR limiter gain values, exponent 


sbr limiterBandsPerOctaveDiv4 


Word 16 


4 


sbr rom.c 


Number of SBR limiter bands, divided by 4 


sbr smoothFilter 


Word 16 


4 


sbr rom.c 


Smoothing filter for gain values 


sbr invlntTable 


Word 16 


49 


sbr rom.c 


Table of 1/x function 


sbr_randomPhase 


Word 16 

or 
Word32 


1 120 


sbr_rom.c 


Random numbers for SBR noise addition 
and PNS. Note: for mono only case the 
data type Wordi 6 can be used. 


sbr qmf 64 640 


Word 16 


340 


sbr rom.c 


QMF window coefficients 


sbr rait sin twiddle L64 


Word 16 


64 


sbr rom.c 


PPT twiddle table 


sbr rait sin twiddle L32 


Word 16 


32 


sbr rom.c 


PPT twiddle table 


sbr_cos_twiddle_L64 


Word 16 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_cos_twiddle_L32 


Word 16 


16 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_sin_twiddle_L64 


Word 16 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_sin_twiddle_L32 


Word 16 


16 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_alt_sin_twiddle_L64 


Word 16 


33 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_cos_twiddle_ds_L32 


Word 16 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_sin_twiddle_ds_L32 


Word 16 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_t_cos_L32 


Wrod16 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_t_sin_L32 


Word 16 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


pHybridResolution 


Word 16 


3 


sbr_rom.c 


Parametric Stereo hybrid filterbank 
resolution 


groupShift 


Word 16 


6 


sbr_rom.c 


Parametric Stereo shift bits for uppermost 
frequency groups 


aRevLinkDecaySer 


Word 16 


3 


sbr_rom.c 


Parametric Stereo all-pass filter 
coefficients 


aFractDelayPhaseFactorReQmf 


Word 16 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 


aPractDelayPhasePactorlmQmf 


Word 16 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 


aPractDelayPhasePactorReSubQmf 


Word 16 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 
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Name 


Data 
type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 


aFractDelayPhaseFactorlmSubQmf 


Word 16 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerReQmfO 


Word 16 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerReQmfl 


Word 16 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerReQmf2 


Word 16 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerlmQmfO 


Word 16 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerlmQmfl 


Word 16 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerlmQmf2 


Word 16 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerReSubQmfO 


Word 16 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerReSubQmfl 


Word 16 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerReSubQmf2 


Word 16 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerlmSubQmfO 


Word 16 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerlmSubQmfl 


Word 16 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorSerlmSubQmf2 


Word 16 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 


aaFractDelayPhaseFactorSerReQmf 


Word 16 


3 


sbr rom.c 


Parametric Stereo phase rotation factor 


aaFractDelayPhaseFactorSerlmQmf 


Word 16 


3 


sbr rom.c 


Parametric Stereo phase rotation factor 


aaFractDelayPhaseFactorSerReSubQmf 


Word 16 


3 


sbr rom.c 


Parametric Stereo phase rotation factor 


aaFractDelayPhaseFactorSerlmSubQmf 


Word 16 


3 


sbr rom.c 


Parametric Stereo phase rotation factor 


scaleFactors 


Word 16 


15 


sbr rom.c 


Parametric Stereo quantization table 


scaleFactorsFine 


Word 16 


31 


sbr rom.c 


Parametric Stereo quantization table 


alphas 


Word 16 


S 


sbr rom.c 


Parametric Stereo quantization table 


p2 6 


Word 16 


6 


sbr rom.c 


Hybrid filterbank coefficients 


p8 13 


Word 16 


13 


sbr rom.c 


Hybrid filterbank coefficients 


sbr_start_f req_1 6 


Words 


16 


sbr rom.c 


SBR frequency scale index 


sbr start freq 22 


Words 


16 


sbr rom.c 


SBR frequency scale index 


sbr start freq 24 


Words 


16 


sbr rom.c 


SBR frequency scale index 


sbr_start_freq_32 


Words 


16 


sbr rom.c 


SBR frequency scale index 


sbr start freq 44 


Words 


16 


sbr rom.c 


SBR frequency scale index 


sbr_start_freq_48 


Words 


16 


sbr rom.c 


SBR frequency scale index 


sbr frame info1 16 


Word 16 


IS 


sbr rom.c 


SBR frequency scale index 


sbr frame info2 16 


Word 16 


IS 


sbr rom.c 


SBR frequency scale index 


sbr frame info4 16 


Word 16 


IS 


sbr rom.c 


SBR frequency scale index 


sbr huff Book EnvLevellOT 


Word 16 


120 


sbr rom.c 


Huffman codeword table SBR 


sbr huff Book EnvLevellOF 


Word 16 


120 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvBalancelOT 


Word 16 


4S 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvBalancelOF 


Word 16 


4S 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvLevelllT 


Word 16 


62 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvLevelllF 


Word 16 


62 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvBalancellT 


Word 16 


24 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvBalancellF 


Word 16 


24 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook NoiseLevelllT 


Word 16 


62 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook NoiseBalancellT 


Word 16 


24 


sbr rom.c 


Huffman codeword table SBR 


aRevLinkDelaySer 


Word 16 


3 


sbr_rom.c 


Parametric Stereo all-pass delay line 
lengths 


groupBorders 


Word 16 


23 


sbr rom.c 


Borders of Parametric Stereo groups 


aGroupToBin 


Word 16 


22 


sbr rom.c 


Parametric Stereo group to bin table 


aHybridToBin 


Word 16 


12 


sbr rom.c 


Parametric Stereo hybrid to bin table 


aDelayToBin 


Word 16 


20 


sbr rom.c 


Parametric Stereo delay to bin table 


aBookPslidTimeDecode 


Word 16 


2S 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslidFreqDecode 


Word 16 


2S 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslccTimeDecode 


Word 16 


14 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslccFreqDecode 


Word 16 


14 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslidFineTimeDecode 


Word 16 


60 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslidFineFreq Decode 


Word 16 


60 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


sbr defaultHeader 


mixed 


22 


sbr rom.c 


Default SBR header data 
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Name 


Data 
type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 


logDualisTable 


Word16 


65 


transcendent.c 


Lookup table for efficient log() 
implementation 


invTable 


Word16 


256 


transcendent.c 


Lookup table for efficient 1/x 
implementation 


Sum 




10222 







NOTE: All Parametric Stereo related coefficients which are marked as such in the table above are obsolete for 
mono only capable decoders. 

4.3.2 Static memory 

This clause contains a listing of all static buffers contributing to the RAM requirements of the encoder and decoder. 

Table 9: Encoder static memory 



Name 


Data type 


Size [16- 
bit word] 


Allocated in 
Source File 


Description 


mdctDelayBuffer 


Word 16 


3200 


aac_ram.c 


Time domain input signal delay , only 
half the size for mono only encoder 


quantSpec 


Word 16 


2048 


aac_ram.c 


Quantized spectrum, only half the size 
for mono only encoder 


scf 


Word 16 


120 


aac_ram.c 


Scalefactors, only half the size for mono 
only encoder 


maxValuelnSfb 


Word 16 


120 


aac_ram.c 


Max. value per calefactor, only half the 
size for mono only encoder 


sidelnfoTabLong 


Word 16 


52 


aac_ram.c 


Table lookup for side information, long 
blocks 


sidelnfoTabShort 


Word 16 


16 


aac_ram.c 


Table lookup for side information, short 
blocks 


aacEncoder 


AAC_ENCODER 


6 851 


aacenc.c 


AAC encoder instance, can be reduced 
to 3809 for mono only encoder 


sbr_QmfStatesAnalysis 


Word 16 


1 280 


sbr_ram.c 


QMF filterbank states buffer, only half 
the size for mono only encoder 


sbr_QmfStatesSynthesis 


Word32 


640 


sbr_ram.c 


QMF filterbank states buffer, not needed 
for mono only encoder 


sbr_envYBuffer 


Word32 


8 192 


sbr_ram.c 


QMF band energy buffer, only half the 
size for mono only encoder 


sbr_quotaMatrix 


Word32 


1 024 


sbr_ram.c 


Tonality values, only half the size for 
mono only encoder 


sbr_thresholds 


Word32 


256 


sbr_ram.c 


Detector parameters, only half the size 
for mono only encoder 


sbr_toncorrBuff 


Word32 


2 240 


sbr_ram.c 


Detector value buffer, only half the size 
for mono only encoder 


ps_lccDataBuffer 


Word32 


40 


sbr_ram.c 


ICC buffer, not needed for mono only 
encoder 


psJidDataBuffer 


Word32 


40 


sbr_ram.c 


lid buffer, not needed for mono only 
encoder 


ps_histQmfBuffer 


Word 16 


1 608 


sbr_ram.c 


QMF history buffer, not needed for 
mono only encoder 


sbrJreqBandTableLO 


Word 16 


15 


sbr_ram.c 


SBR frequency band table, low 
resolution 


sbrJreqBandTableHI 


Word 16 


29 


sbr_ram.c 


SBR frequency band table, high 
resolution 


sbr V k master 


Word 16 


29 


sbr ram.c 


SBR frequency band table index 


sbr_guideScfb 


Word 16 


56 


sbr_ram.c 


Additional sine detection parameter, 
only half the size for mono only encoder 


sbr_detectionVectors 


Word 16 


112 


sbr_ram.c 


Additional sine detection parameter, 
only half the size for mono only encoder 


sbr_prevEnvelopeCompensat 
ion 


Word 16 


56 


sbr_ram.c 


Additional sine detection parameter, 
only half the size for mono only encoder 


sbr_guideVectorDetected 


Word 16 


112 


sbr_ram.c 


Additional sine detection parameter, 
only half the size for mono only encoder 
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Name 


Data type 


Size [16- 
bit word] 


Allocated in 
Source File 


Description 


sbrEncoder 


SBR_ENCODER 


3 650 


sbr_main.c 


SBR encoder instance, can be reduced 
to 1722 for mono only encoder 


outputBuffer 


Words 


384 


main.c 


Bitstream output buffer 


inputBuffer 


Word 16 


8 234 


main.c 


Time domain input signal buffer, only 
half the size for mono only encoder 


up2Sampler 


RESAMPLER FIR 
_2_1 


144 


main.c 


1 :2 FIR resampler instance (includes 
states) , only half the size for mono only 
encoder 


downSSampler 


RESAMPLER FIR 
_3_2 


208 


main.c 


3:2 FIR resampler instance (includes 
states) , only half the size for mono only 
encoder 


down2Sampler 


RESAMPLER FIR 
_2_1 


144 


main.c 


2:1 FIR resampler instance (includes 
states) , only half the size for mono only 
encoder 


Sum 




40 900 







Table 10: Decoder static memory 



Name 


Data type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 


OverlapBuffer[nChan] 


Word 16 


1 024 


aac_ram.c 


Delay buffer for overlap and add, 
only half the size for mono only 
decoder 


AacDecoderlnstance 


AAC DECODER INS 
TANCE 


12 


aacdecoder.c 


AAC decoder instance 


sbrPayloadBuffer 


short 


128 


aacdecoder.c 


SBR payload buffer 


Stream Info 


CStreamlnfo 


7 


aac ram.c 


Bitstream information 


AacDecoderStaticChannellnfo[ 
nChan] 


CaacDecoderStaticCh 
annellnfo 


16 


aac_ram.c 


Channel information, only half the 
size for mono only decoder 


PnsStaticlnterChannelData 


Word 16 


2 


aac ram.c 


PNS static data 


Concealmentlnfolnstance 


CConcealmentlnfo 


4 127 


aac ram.c 


Concealment static data 


sbr_CodecQmfStatesAnalysis 


Word 16 


640 


sbr ram.c 


QMF analysis filter bank states 


sbr_GainSmooth_m 


Word 16 


96 


sbr_ram.c 


Gain smoothing filter states, 
mantissa 


sbr_GainSmooth_e 


Word 16 


96 


sbr_ram.c 


Gain smoothing filter states, 
exponent 


sbr_NoiseSmooth_m 


Word 16 


96 


sbr_ram.c 


Noise level smoothing filter states, 
mantissa 


sbr_QmfStatesSynthesis 


Word 16 


2 560 


sbr ram.c 


QMF synthesis filter bank states 


sbr_OverlapBuffer 


Word32 


3 072 


sbr_ram.c 


SBR delay buffer, only half the 
size for mono only decoder 


sbr LpcFilterStatesReal 


Word32 


256 


sbr ram.c 


LPC filter states 


sbr_LpcFilterStateslmag 


Word32 


256 


sbr_ram.c 


LPC filter states, obsolete for 
mono only decoder 


sbr_TransposerSettings 


TRANSPOSER SETT 
INGS 


61 


sbr_ram.c 


Transposer configuration 
parameters 


FreqBandData 


FREQ BAND DATA 


164 


sbr ram.c 


SBR Frequency band information 


PrevFrameData[nChan] 


SBR PREV FRAME 
DATA 


120 


sbr_ram.c 


SBR previous frame data, only half 
the size for mono only decoder 


sbrDecoderlnstance 


SBR DECODER INS 
TANCE 


797 


sbrdecoder.c 


SBR decoder instance 


timeData 


Word 16 


4 096 


main.c 


Output buffer for time-domain 
signal, only half the size for mono 
only decoder 


inBuffer 


short 


768 


main.c 


Input buffer for bitstream 


splineResamplerlnstance 


SPLINE RESAMPLE 
R 


19 


spline_resam 
pler.c 


Spline resampler instance 


Sum 




18 413 
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4.3.3 Dynamic memory 

This clause contains a listing of all dynamic buffers contributing to the RAM requirements of the encoder and decoder. 
Dynamic memory can be re-used outside of the encoder or decoder application. 

Table 1 1 : Encoder dynamic memory 



Name 


Data type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 


ps_tempQmfBuffer 


Word16 


1 608 


sbr_ram.c 


NOTE: 


reused in AAC encoder, not needed for 
mono only encoder 


sbr envRBuffer 


Word16 


4 096 


sbr ram.c 


NOTE: 


reused in AAC encoder 


sbr envlBuffer 


Word16 


4 096 


sbr ram.c 


NOTE: 


reused in AAC encoder 


sbr transients 


Word32 


384 


sbr ram.c 


NOTE: 


reused in AAC encoder 


Sum 




10 184 







Table 12: Decoder dynamic memory 



Name 


Data type 


Size 
[16-bit 
word] 


Allocated in 
Source File 


Description 


WorkBufferCore 


Word32 


4 096 


aac ram.c 


NOTE: reused in SBR decoder 


WorkBuffen 


Word32 


4 096 


sbr ram.c 


Work buffer, obsolete for mono only decoder 


Sum 




8192 







4.3.4 Maximum stack size 

This clause contains tables for the encoder and the decoder which describe the call stack that results in the maximum 
stack size usage. 
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Table 13: Encoder call stack 



Function 


Local variables / Function call arguments 


Stack used 
[16-bit 
words] 


main 


AACENC_CONFIG config; 


8 




Word16 error; 


1 




Flag bEncodeMono; 


1 




Word16ch; 


1 




Word16 dummy; 


1 




Word32 bitrate; 


2 




Word16 nChannelsAAC, nChannelsSBR; 


2 




Word32 sampleRateAAC; 


2 




Word32 frmCnt ; 


2 




Word32 bandwidth; 


1 




UWord16 numAncDataBytes; 


2 




UWord8ancDataBytes[MAX_PAYLOAD_SIZE]; 


64 




Word32 numSamplesRead; 


2 




Flag bDingleRate; 


1 




Flag useParametricStereo; 


1 




Word32 coreWriteOffset; 


2 




Word32 coreReadOffset; 


2 




Word32 envWriteOffset; 


2 




Word32 envReadOffset; 


2 




Word32 writeOffset; 


2 




struct AAC ENCODER *hAacEnc; 






struct SBR_ENCODER *hEnvEnc; 






Flag bDoUpsample; 






Flag upsampleReadOffset; 






Word16 inSamples; 






Flag bDo32Resample; 






Word16 nRuns; 






Word16 *resamplerScratch; 






UWord32 numOutBytes; 


2 




Word32 i; 


2 




UWordS *bitstreamOut; 






Word32 *nOutBytes; 






Word16 numEncSamples; 






Flag downsample; 


=116 


AacEncEncode 


struct AAC_ENCODER *aacEnc; 
Word16*timeSignal; 
const UWordS *ancBytes; 
UWord16 *numAncBytes; 
UWordS *outBytes; 
Word32 *numOutBytes; 
ELEMENT INFO *ellnfo; 
Word16globUsedBits; 






Word16 ancDataBytes, ancDataBytesLeft; 


=9 


QCMain 


QC_STATE* hoc, 

Word16 nChannels, 

ELEMENT_BITS* elBits, 

ATS ELEMENT* adjThrStateElement, 

PSY OUT CHANNEL psyOutChannel[MAX CHANNELS PER ELEM], 

PSY OUT ELEMENT* psyOutElement, 

QC OUT CHANNEL qcOutChannel[MAX CHANNELS PER ELEM], 

QC_OUT_ELEMENT* qcOutElement, 

Word16 ancillaryDataBytes 

Word16ch; 






Word 16 


120 




logSfbFormFactor[MAX CHANNELS PER ELEM][MAX GROUPED SFB]; 






Word 16 


120 




sfbNRelevantLines[MAX CHANNELS PER ELEM][MAX GROUPED SFB]; 






Word16logSfbEnergy[MAX CHANNELS PER ELEM][MAX GROUPED SFB]; 


120 




Word16maxChDynBits[MAX CHANNELS PER ELEM]; 


2 




Word16chBitDistribution[MAX CHANNELS PER ELEM]; 


2 
=375 
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Function 


Local variables / Function call arguments 


Stack used 
[16-bit 
words] 


AdjustThresholds 


ADJ THR STATE *adjThrState; 

ATS ELEMENT *AdjThrStateElement; 

PSY OUT CHANNEL psyOutChannel[MAX CHANNELS PER ELEM]; 

PSY_OUT_ELEMENT *psyOutElement; 

Word16 *chBitDistribution; 

Word16logSfbEnergy[MAX CHANNELS PER ELEM][MAX GROUPED SFB]; 

Word16sfbNRelevantLines[MAX_CHANNELS][MAX_GROUPED_SFB]; 

const Word16 nChannels; 

QC_OUT_ELEMENT *qcOE; 

const Word16 avgBits; 

const Word1 6 bitresBits; 

const Word16 maxBitresBits; 

const Word16 maxBitFac; 

const Word1 6 sidelnfoBits; 






Word16 noRedPe, grantedPe, grantedPeCorr; 


2 




Word16 curWindowSequence; 






PE DATApeData; 


667 




Word16bitFactor; 






Word16ch; 


=686 


adaptThresholdsToPe 


PSY OUT CHANNEL psyOutChannel[MAX CHANNELS PER ELEM]; 
PSY OUT ELEMENT *psyOutElement; 

Word16logSfbEnergy[MAX_CHANNELS_PER_ELEM][MAX_GROUPED_SFB]; 
PE_DATA *peData; 
const Word16 nChannels; 
const Word1 6 desiredPe; 
AH PARAM*ahParam; 
MINSNR_ADAPT_PARAM *msaParam; 






Word16 noRedPe, redPe, redPeNoAH; 


4 




Word16 constPart, constPartNoAH; 


2 




Word16 nActiveLines, nActiveLinesNoAH; 


2 




Word16desiredPeNoAH; 


1 




Word32 redVal, avgThrExp; 


4 




Word16iter; 


1 
=22 


correctThresh 


PSY OUT CHANNEL psyOutChannel[MAX CHANNELS PER ELEM]; 


1 




Word16 ahFlag[MAX_CHANNELS][MAX_GROUPED_SFB]; 


1 




PE DATA *peData; 


1 




Word32 thrExp[MAX_CHANNELS][MAX_GROUPED_SFB]; 


1 




const Word32 redVal; 


2 




const Word1 6 nChannels; 


1 




const Word32 deltaPe; 


2 




Word16ch, sfb, sfbGrp; 


3 




PSY OUT CHANNEL *psyOutChan; 


1 




PE CHANNEL DATA *peChanData; 


1 




Word32 deltaSfbPe; 


2 




Word32 sfbPeFactors[MAX CHANNELS][MAX GROUPED SFB], normFactor; 


242 




Word32 sfbEn, sfbThr; 


4 




Word32 sfbThrReduced; 


2 




Word32 thrFactor; 


2 
=266 


ffr_pow2_xy 


Word32 X, Word32 y; 


4 




Word32 iPart,fPart; 


4 




Word32 res; 


2 




Word32 tmp, tmp2; 


4 




Word16 shift, shift2; 


2 




Word16 denom_h, denomj; 


2 
=18 




Sum 


992 
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Table 14: Decoder call stack 



Function 


Local variables / Function call arguments 


Stack used 
[16-bit 
words] 


mainQ 


Flag endOfFile; 

Flag frameOk; 

Word32 i; 

Word32written16; 

Words channelMode; 

struct BIT_BUF bitBuf, *hBitBuf; 

AACDECODER aacDecoderlnfo; 

SBRBITSTREAM streamSBR; 

SBRDECODER sbrDecoderlnfo; 

HANDLE_SPLINE_RESAMPLERsplineResampler; 

Word32 frameSize; 

Word32 sampleRate, outputSampleRate; 

Words numChannels; 

Words numChannelsLast; 

Word16 numOutSamples; 

Flag bDownSample; 

Flag fosr16; 

Flag fosrS; 

Flag bBltstreamDownMIx; 

Flag bValidMode; 


1 
1 
2 
2 
1 
14 
1 
6 
1 
1 
2 
4 
1 
1 
1 
1 
1 
1 
1 
1 
=44 


applySBRQ 


SBRDECODER self, 

SBRBITSTREAM * Bitstr, 

Word16*timeData, 

Words *numChannels, 

Flag SbrFrameOK, 

Flag bDownSample, 

Flag bBltstreamDownMIx 

Word16lr; 

Word32 i; 

Words prevStereo, prevPs; 

Words psPresent; 

Words stereo; 

Words readHeader; 

Word32 err; 

SBR CHANNEL *SbrChannel; 

struct BIT BUF bitBuf; 

HANDLE SBR HEADER DATA hHeaderData; 

SBR_HEADER_STATUS headerStatus; 

Word32 codecFrameSize; 

SBR SYNC STATE InitialSyncState; 

SBR FRAME DATA *hFrameDataLeft; 

SBR FRAME DATA *hFrameDataRight; 

Flag bUseLP; 


1 
1 
1 
1 
1 
1 
1 
1 
2 
2 
1 
1 
1 
2 
1 
1 
1 
1 
2 
1 
1 
1 
1 
=2S 
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Function 



Local variables / Function call arguments 



Stack used 
[16-bit 
words] 



sbr_dec() 



HANDLE_SBR_DEC hSbrDec, 

Word16*timeln, 

Word16*timeOut, 

HANDLE_SBR_HEADER_DATAhHeaderData, 

HANDLE_SBR_FRAME_DATAhFrameData, 

HANDLE_SBR_PREV_ 

FRAME_DATA hPrevFrameData, 

HANDLE_PS_DEC hPS, 

HANDLE_SBR_QMF_FILTER_BANKhSynthesisQmfBankRight, 

SBR_SCALE_FACTOR*sbrScaleFactorRight, 

Flag applyProcessing, 

Flag bUseLP 

Word32 I, k; 

Word16 slot, reserve; 

Word16 saveLbScale; 

Word 16 ovjen; 

Word32 *QmfBufferReal[MAX_ENV_COLS]; 

Word32 *QmfBufferlmag[MAX_ENV_COLS]; 

Word32 *ptr; 

Word16 noCols; 



38 
38 



98 



cplxSynthesisQmfFilteringO 



Word32 **qmfReal, 

Word32 **qmflmag, 

Word32 splitSlot, 

SBR_SCALE_FACTOR*sbrScaleFactor, 

Word16*timeOut, 

HANDLE_SBR_QMF_FILTER_BANKqmfBank, 

HANDLE_PS_DEC hPS, 

Flag active, 

Flag bUseLP 

Word16i,j; 

Word16 codScalefactor; 

Word16 sbrScalefactor; 

Word16 outScalefactor; 

Word16 scaleFactorLowBand; 

Word16 scaleFactorHlghBand; 

Word16*filterStates; 

Word32qmfReal2[NO_SYNTHESIS_CHANNELS]; 

Word16 no_synthesis_channels; 

Word32qmfRealTmp[NO_SYNTHESIS_CHANNELS]; 

Word32 *qmflmagTmp; 

Word8 env; 

Word16 scaleFactorLowBandSplit; 

Word32 *imagSlot; 



128 
128 

:277 



inverseModulationLPQ 



Word32 *qmfReal, 

Word32 *qmfReal2, 

const Word16 scaleFactorLowBand, 

const Word16 scaleFactorHlghBand, 

HANDLE_SBR_QMF_FILTER_BANKsynQmf 

Wordiei; 

const Word16 L; 

const Word16 M; 

Word32timeOut[2*NO_SYNTHESIS_CHANNELS]; 



256 

:264 



dct2 



Word32 *data, 

Word32 *tmp, 

Word32 L, 

HANDLE_SBR_QMF_FILTER_ 

WordIG cosphi,sinphi; 

Wordiei; 

Word32 M; 

Word32 N; 

Word32 a1,a2,a3,a4,a5,a6; 



BANK qmf Bank 



2 

2 

12 

24 
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Function 


Local variables / Function call arguments 


Stack used 
[16-bit 
words] 


DSP_fft32x32s() 


Word32 npoints 
Word32 *ptr_x 


2 

1 

= 3 


fft32() 


Word32 x[] 

Word16m; 

Word32 re, ie, ro, io, rx, ix ; 

Word32 *x1 m, *x2m, *x1 mm, *x2mm; 


2 

1 

12 

4 

= 19 


fft2x16() 


Word32 x[] 

Word16 sch, sh, ch; 

Word32 aO, a1 , a2, a3, aOO, alO, a20, a30 ; 

Word32tr, ti, vr, vi ; 

Word32 even [32], odd [32] ; 


2 

3 

16 

8 

128 

= 157 


fixmul_32x16b() 


Word32 a; 
Word16b; 
Word16hi1 lol 


2 

1 

2 

= 5 




Sum 


919 



5 File formats 

This clause describes the file formats used by the encoder and decoder programs. 

5.1 Audio input file (encoder input/decoder output) 

The audio input files read by the encoder and written by the decoder are 16-bit PCM wave files. For convenient 
handling of wave files a precompiled audio-file format library is used. 

5.2 Bitstream file format (encoder output/decoder input) 

The encoder program writes and the decoder program reads raw frames packetized in access units as described by 
3GPP TS 26.244 [10]. For packetization the ISO media library is used. A precompiled library is used. 

5.3 Error pattern file (decoder input) 

The decoder program can optionally process an additional input file which describes an error pattern. The format of the 
error pattern file is 1 character per line. Each line corresponds to one frame, where a "0" indicates that the respective 
frame has been transmitted without errors, while a "1" indicates that the corresponding frame has been lost and error 
concealment shall be applied by the decoder. 
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Annex A (informative): 
Weighted MOPS 



The complexity numbers for the Enhanced aacPlus audio codec can be found in the following tables, the numbers have 
been derived using the "allcat.wav" item, which holds all the material from the selection test concatenated in one single 
item. For every test case the average and worst frame weighted MOPS figure has been derived. The worst case wMOPS 
figure over all test cases has been marked in blue. 

The fixed-point C-code contains a pre-compiler directive named 

'ACCOUNT_ETSIOP_OVERHEAD_SPLITWORD32'. If this pre-compiler directive is set during compilation, the 
complexity figures will be as given in Table 15. If this pre-compiler directive is not set during compilation, the 
complexity figures will be as given in Table 16. Regarding the details of the corresponding difference in the fixed-point 
C-code, please see the comments in the SplitWord32() function in intrinsics.c. 

Table A.1 : Weighted MOPS figures with ACCOUNT_ETSIOP_OVERHEAD_SPLITWORD32 set 





Test Case 


IVIono Encoder 


Stereo Encoder 


Decoder 


Decoder, mono 
only 


wIVIOPS 

[average / 

worst frame] 


14m 


26.51 / 28.87 


26.50/31.61 


19.15/21.20 


14.73/16.80 


18s 


___ 


61.38/65.25 


35.18/38.04 


15.14/17.39 


24m 


29.51/34.28 


29.51/34.26 


20.98 / 23.84 


15.93/18.74 


24s 


___ 


63.47/68.17 


37.35/40.98 


15.93/18.72 


32s 


___ 


64.61 / 71.02 


38.39 / 42.28 


16.47/19.60 


48s 


— 


64.17/77.63 


32.65/38.46 


21.96/26.83 



Table A.2: Weighted MOPS figures witli ACCOUNT_ETSIOP_OVERHEAD_SPLITWORD32 not set 





Test Case 


Mono Encoder 


Stereo Encoder 


Decoder 


Decoder, mono 
only 


wMOPS 

[average / 

worst frame] 


14m 


23.80/25.41 


23.79 / 29.04 


15.86/17.73 


12.38/14.38 


18s 


___ 


51.14/53.92 


29.35/32.07 


12.77/14.95 


24m 


26.52 /29.60 


26.52/29.66 


17.53/20.13 


13.51/16.21 


24s 


___ 


53.08/56.06 


31.17/34.64 


13.57/16.22 


32s 


___ 


54.11/58.39 


32.08 / 35.75 


14.05/17.09 


48s 


— 


57.46 / 65.89 


27.88/33.43 


18.53/23.22 
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Annex B (informative): 
Change history 



Change history 


Date 


TSG SA# 


TSG Doc. 


CR 


Rev 


Subject/Comment 


Old 


New 


2005-03 


27 


SP-050146 






Approved at TSG SA#27 


1.0.0 


6.0.0 


2005-06 


28 


SP-050251 


001 




Correction to C-code: Corrections to ETSI operator 
usage 


6.0.0 


6.1.0 


2005-06 


28 


SP-050251 


002 




Correction to C-code: Avoid reading of non-initialized 
variable 


6.0.0 


6.1.0 


2005-06 


28 


SP-050251 


003 




Correction to C-code: fixes for error concealment 


6.0.0 


6.1.0 


2005-09 


29 


SP-050426 


0004 




Correction to C-code: enable 44.1 kHz input material 
encoding (fixed-point code) 


6.1.0 


6.2.0 


2005-09 


29 


SP-050426 


0005 




Correction to C-Code: Bitrate dependancy of AAC block 
switching threshold 


6.1.0 


6.2.0 


2005-09 


29 


SP-050426 


0006 




Correction to C-Code: prevent overflow in parameter 
estimation of Parametric Stereo IID value 


6.1.0 


6.2.0 


2005-09 


29 


SP-050426 


0007 




Correction to C-Code: smoothing of SBR noise values 


6.1.0 


6.2.0 


2005-09 


29 


SP-050426 


0008 




Correction to C-Code: removal of obsolete table (fixed- 
point code) 


6.1.0 


6.2.0 


2005-09 


29 


SP-050426 


0009 




Correction to C-Code: rounding in TNS parcor 
coefficient calculation 


6.1.0 


6.2.0 


2005-12 


30 


SP-050786 


0011 




Correction to C-code: encoder tuning table entry for 
44.1 kHz was wrong 


6.2.0 


6.3.0 


2005-12 


30 


SP-050786 


0012 




Correction to C-code: encoder bitrate switching 
simulation toolset 


6.2.0 


6.3.0 


2006-09 


33 


SP-060595 


0015 


1 


Correction of written specification: correct memory 
tables (fixed-point code) 


6.3.0 


6.4.0 


2007-03 


35 


SP-070025 


0017 


1 


Bugfix for Enhanced aacPlus encoder when operated at 
44.1 kHz 


6.4.0 


6.5.0 


2007-09 


37 


SP-070628 


0019 




Adding safety code to avoid encoder runtime-assertion 


6.5.0 


6.6.0 


2007-09 


37 


SP-070628 


0021 




Prevent arithmetic overflow during estimation of 
perceptual entropy in AAC encoder 


6.5.0 


6.6.0 


2007-09 


37 


SP-070628 


0023 




Prevent out-of-bounds memory access of encoder in 
parametric stereo mode 


6.5.0 


6.6.0 
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